-
DingiStyleLayeris an abstract base class for style layers. A style layer manages the layout and appearance of content at a specific z-index in a style. AnDingiStyleobject consists of one or moreDingiStyleLayerobjects.Each style layer defined by the style JSON file is represented at runtime by an
DingiStyleLayerobject, which you can use to refine the map’s appearance. You can also add and remove style layers dynamically.Create instances of
DingiBackgroundStyleLayerand the concrete subclasses ofDingiForegroundStyleLayerin order to useDingiStyleLayer‘s properties and methods. You do not create instances ofDingiStyleLayerdirectly, and do not create your own subclasses of this class.Do not add
See moreDingiStyleLayerobjects to thestyleproperty of aDingiMapViewbefore-mapView:didFinishLoadingStyle:is called.Declaration
Objective-C
@interface DingiStyleLayer : NSObjectSwift
class DingiStyleLayer : NSObject
-
DingiForegroundStyleLayeris an abstract superclass for style layers whose content is defined by anDingiSourceobject.Create instances of
See moreDingiRasterStyleLayer,DingiHillshadeStyleLayer, and the concrete subclasses ofDingiVectorStyleLayerin order to useDingiForegroundStyleLayer‘s methods. Do not create instances ofDingiForegroundStyleLayerdirectly, and do not create your own subclasses of this class.Declaration
Objective-C
@interface DingiForegroundStyleLayer : DingiStyleLayerSwift
class DingiForegroundStyleLayer : DingiStyleLayer
-
An
DingiBackgroundStyleLayeris a style layer that covers the entire map. Use a background style layer to configure a color or pattern to show below all other map content. If the style’s other layers use the Mapbox Streets source, the background style layer is responsible for drawing land, whereas the oceans and other bodies of water are drawn byDingiFillStyleLayerobjects.A background style layer is typically the bottommost layer in a style, because it covers the entire map and can occlude any layers below it. You can therefore access it by getting the last item in the
DingiStyle.layersarray.If the background style layer is transparent or omitted from the style, any portion of the map view that does not show another style layer is transparent.
See moreDeclaration
Objective-C
@interface DingiBackgroundStyleLayer : DingiStyleLayerSwift
class DingiBackgroundStyleLayer : DingiStyleLayer
-
An
DingiRasterStyleLayeris a style layer that renders georeferenced raster imagery on the map, especially raster tiles.Use a raster style layer to configure the color parameters of raster tiles loaded by an
DingiRasterTileSourceobject or raster images loaded by anDingiImageSourceobject. For example, you could use a raster style layer to render Mapbox Satellite imagery, a raster tile set uploaded to Mapbox Studio, or a raster map authored in TileMill, the classic Mapbox Editor, or Mapbox Studio Classic.Raster images may also be used as icons or patterns in a style layer. To register an image for use as an icon or pattern, use the
-[DingiStyle setImage:forName:]method. To configure a point annotation’s image, use theDingiAnnotationImageclass.You can access an existing raster style layer using the
-[DingiStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theDingiStyle.layersproperty. You can also create a new raster style layer and add it to the style using a method such as-[DingiStyle addLayer:].Example
See morelet layer = DingiRasterStyleLayer(identifier: "clouds", source: source) layer.rasterOpacity = NSExpression(forConstantValue: 0.5) mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiRasterStyleLayer : DingiForegroundStyleLayerSwift
class DingiRasterStyleLayer : DingiForegroundStyleLayer
-
DingiVectorStyleLayeris an abstract superclass for style layers whose content is defined by anDingiShapeSourceorDingiVectorTileSourceobject.Create instances of
See moreDingiCircleStyleLayer,DingiFillStyleLayer,DingiFillExtrusionStyleLayer,DingiHeatmapStyleLayer,DingiLineStyleLayer, andDingiSymbolStyleLayerin order to useDingiVectorStyleLayer‘s properties and methods. Do not create instances ofDingiVectorStyleLayerdirectly, and do not create your own subclasses of this class.Declaration
Objective-C
@interface DingiVectorStyleLayer : DingiForegroundStyleLayerSwift
class DingiVectorStyleLayer : DingiForegroundStyleLayer
-
An
DingiCircleStyleLayeris a style layer that renders one or more filled circles on the map.Use a circle style layer to configure the visual appearance of point or point collection features. These features can come from vector tiles loaded by an
DingiVectorTileSourceobject, or they can beDingiPointAnnotation,DingiPointFeature,DingiPointCollection, orDingiPointCollectionFeatureinstances in anDingiShapeSourceorDingiComputedShapeSourceobject.A circle style layer renders circles whose radii are measured in screen units. To display circles on the map whose radii correspond to real-world distances, use many-sided regular polygons and configure their appearance using an
DingiFillStyleLayerobject.You can access an existing circle style layer using the
-[DingiStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theDingiStyle.layersproperty. You can also create a new circle style layer and add it to the style using a method such as-[DingiStyle addLayer:].Example
See morelet layer = DingiCircleStyleLayer(identifier: "circles", source: population) layer.sourceLayerIdentifier = "population" layer.circleColor = NSExpression(forConstantValue: UIColor.green) layer.circleRadius = NSExpression(format: "mgl_interpolate:withCurveType:parameters:stops:($zoomLevel, 'exponential', 1.75, %@)", [12: 2, 22: 180]) layer.circleOpacity = NSExpression(forConstantValue: 0.7) layer.predicate = NSPredicate(format: "%K == %@", "marital-status", "married") mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiCircleStyleLayer : DingiVectorStyleLayerSwift
class DingiCircleStyleLayer : DingiVectorStyleLayer
-
An
DingiFillStyleLayeris a style layer that renders one or more filled (and optionally stroked) polygons on the map.Use a fill style layer to configure the visual appearance of polygon or multipolygon features. These features can come from vector tiles loaded by an
DingiVectorTileSourceobject, or they can beDingiPolygon,DingiPolygonFeature,DingiMultiPolygon, orDingiMultiPolygonFeatureinstances in anDingiShapeSourceorDingiComputedShapeSourceobject.You can access an existing fill style layer using the
-[DingiStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theDingiStyle.layersproperty. You can also create a new fill style layer and add it to the style using a method such as-[DingiStyle addLayer:].Example
See morelet layer = DingiFillStyleLayer(identifier: "parks", source: parks) layer.sourceLayerIdentifier = "parks" layer.fillColor = NSExpression(forConstantValue: UIColor.green) layer.predicate = NSPredicate(format: "type == %@", "national-park") mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiFillStyleLayer : DingiVectorStyleLayerSwift
class DingiFillStyleLayer : DingiVectorStyleLayer
-
An
DingiFillExtrusionStyleLayeris a style layer that renders one or more 3D extruded polygons on the map.Use a fill-extrusion style layer to configure the visual appearance of polygon or multipolygon features. These features can come from vector tiles loaded by an
DingiVectorTileSourceobject, or they can beDingiPolygon,DingiPolygonFeature,DingiMultiPolygon, orDingiMultiPolygonFeatureinstances in anDingiShapeSourceorDingiComputedShapeSourceobject.You can access an existing fill-extrusion style layer using the
-[MGLStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theMGLStyle.layersproperty. You can also create a new fill-extrusion style layer and add it to the style using a method such as-[MGLStyle addLayer:].Example
See morelet layer = DingiFillExtrusionStyleLayer(identifier: "buildings", source: buildings) layer.sourceLayerIdentifier = "building" layer.fillExtrusionHeight = NSExpression(forKeyPath: "height") layer.fillExtrusionBase = NSExpression(forKeyPath: "min_height") layer.predicate = NSPredicate(format: "extrude == 'true'") mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiFillExtrusionStyleLayer : DingiVectorStyleLayerSwift
class DingiFillExtrusionStyleLayer : DingiVectorStyleLayer
-
An
DingiHeatmapStyleLayeris a style layer that renders a heatmap.A heatmap visualizes the spatial distribution of a large, dense set of point data, using color to avoid cluttering the map with individual points at low zoom levels. The points are weighted by an attribute you specify. Use a heatmap style layer in conjunction with point or point collection features. These features can come from vector tiles loaded by an
DingiVectorTileSourceobject, or they can beDingiPointAnnotation,DingiPointFeature,DingiPointCollection, orDingiPointCollectionFeatureinstances in anDingiShapeSourceorDingiComputedShapeSourceobject.Consider accompanying a heatmap style layer with an
DingiCircleStyleLayerorDingiSymbolStyleLayerat high zoom levels. If you are unsure whether the point data in anDingiShapeSourceis dense enough to warrant a heatmap, you can alternatively cluster the source using theDingiShapeSourceOptionClusteredoption and render the data using anDingiCircleStyleLayerorDingiSymbolStyleLayer.You can access an existing heatmap style layer using the
-[DingiStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theDingiStyle.layersproperty. You can also create a new heatmap style layer and add it to the style using a method such as-[DingiStyle addLayer:].Example
See morelet layer = DingiHeatmapStyleLayer(identifier: "earthquake-heat", source: earthquakes) layer.heatmapWeight = NSExpression(format: "mgl_interpolate:withCurveType:parameters:stops:(magnitude, 'linear', nil, %@)", [0: 0, 6: 1]) layer.heatmapIntensity = NSExpression(format: "mgl_interpolate:withCurveType:parameters:stops:($zoomLevel, 'linear', nil, %@)", [0: 1, 9: 3]) mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiHeatmapStyleLayer : DingiVectorStyleLayerSwift
class DingiHeatmapStyleLayer : DingiVectorStyleLayer
-
An
DingiHillshadeStyleLayeris a style layer that renders raster digital elevation model (DEM) tiles on the map.Use a hillshade style layer to configure the color parameters of raster tiles loaded by an
DingiRasterDEMSourceobject. For example, you could use a hillshade style layer to render Mapbox Terrain-RGB data.To display posterized hillshading based on vector shapes, as with the Mapbox Terrain source, use an
DingiVectorTileSourceobject in conjunction with severalDingiFillStyleLayerobjects.You can access an existing hillshade style layer using the
-[MGLStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theMGLStyle.layersproperty. You can also create a new hillshade style layer and add it to the style using a method such as-[MGLStyle addLayer:].Example
See morelet layer = DingiHillshadeStyleLayer(identifier: "hills", source: source) layer.hillshadeExaggeration = NSExpression(forConstantValue: 0.6) if let canalShadowLayer = mapView.style?.layer(withIdentifier: "waterway-river-canal-shadow") { mapView.style?.insertLayer(layer, below: canalShadowLayer) }Declaration
Objective-C
@interface DingiHillshadeStyleLayer : DingiForegroundStyleLayerSwift
class DingiHillshadeStyleLayer : DingiForegroundStyleLayer
-
An
DingiLineStyleLayeris a style layer that renders one or more stroked polylines on the map.Use a line style layer to configure the visual appearance of polyline or multipolyline features. These features can come from vector tiles loaded by an
DingiVectorTileSourceobject, or they can beDingiPolyline,DingiPolylineFeature,DingiMultiPolyline, orDingiMultiPolylineFeatureinstances in anDingiShapeSourceorDingiComputedShapeSourceobject.You can access an existing line style layer using the
-[MGLStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theMGLStyle.layersproperty. You can also create a new line style layer and add it to the style using a method such as-[MGLStyle addLayer:].Example
See morelet layer = DingiLineStyleLayer(identifier: "trails-path", source: trails) layer.sourceLayerIdentifier = "trails" layer.lineWidth = NSExpression(format: "mgl_interpolate:withCurveType:parameters:stops:($zoomLevel, 'exponential', 1.5, %@)", [14: 2, 18: 20]) layer.lineColor = NSExpression(forConstantValue: UIColor.brown) layer.lineCap = NSExpression(forConstantValue: "round") layer.predicate = NSPredicate(format: "%K == %@", "trail-type", "mountain-biking") mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiLineStyleLayer : DingiVectorStyleLayerSwift
class DingiLineStyleLayer : DingiVectorStyleLayer
-
An
DingiSymbolStyleLayeris a style layer that renders icon and text labels at points or along lines on the map.Use a symbol style layer to configure the visual appearance of feature labels. These features can come from vector tiles loaded by an
DingiVectorTileSourceobject, or they can beDingiShapeorDingiFeatureinstances in anDingiShapeSourceorDingiComputedShapeSourceobject.You can access an existing symbol style layer using the
-[DingiStyle layerWithIdentifier:]method if you know its identifier; otherwise, find it using theDingiStyle.layersproperty. You can also create a new symbol style layer and add it to the style using a method such as-[DingiStyle addLayer:].Example
See morelet layer = DingiSymbolStyleLayer(identifier: "coffeeshops", source: pois) layer.sourceLayerIdentifier = "pois" layer.iconImageName = NSExpression(forConstantValue: "coffee") layer.iconScale = NSExpression(forConstantValue: 0.5) layer.text = NSExpression(forKeyPath: "name") layer.textTranslation = NSExpression(forConstantValue: NSValue(cgVector: CGVector(dx: 10, dy: 0))) layer.textJustification = NSExpression(forConstantValue: "left") layer.textAnchor = NSExpression(forConstantValue: "left") layer.predicate = NSPredicate(format: "%K == %@", "venue-type", "coffee") mapView.style?.addLayer(layer)Declaration
Objective-C
@interface DingiSymbolStyleLayer : DingiVectorStyleLayerSwift
class DingiSymbolStyleLayer : DingiVectorStyleLayer
Style Layers Reference